}
row {
padding: 10px 4px;
+ @include focus-ring();
> label {
padding-left: 6px;
&:selected:hover:dir(ltr), &:selected:hover:dir(rtl) {
background-color: darken($menu_selected_color,5%);
}
- &:focus:focus-visible {
- outline-width: 0;
- background-color: $selected_bg_color;
- color: $selected_fg_color;
- }
&.activatable:active, &.activatable:selected:active {
box-shadow: none; // #3413
}
padding: 0 8px;
border-radius: $menu-margin;
margin: 0 $menu-margin 2px;
-
- &:hover,
- &:focus-visible:focus-within {
+ @include focus-ring($focus-state: 'focus-visible:focus-within');
+ &:hover {
background-color: darken($menu_selected_color, 5%);
}
background-color: darken($menu_selected_color,5%);
}
- &:focus-visible:focus-within {
- outline-width: 0;
- color: $selected_fg_color;
- background-color: $selected_bg_color;
- &:hover { background-color: darken($selected_bg_color,10%); }
- }
}
&:disabled { color: $insensitive_fg_color; }
// If $within is true, use focus-within instead of focus:focus-visible
//
@mixin focus-ring($target: null, $width: 2px, $offset: -$width, $outer: false, $focus-state: 'focus:focus-visible', $fc: $focus_border_color) {
+ transition-property: outline, outline-width, outline-offset, outline-color;
+ transition-duration: 300ms;
+ animation-timing-function: ease-in-out;
& #{$target} {
outline: 0 solid transparent;
outline-offset: if($outer, $offset + 4px, $offset + $width + 4px);